Адміністрація вирішила продати даний сайт. За детальною інформацією звертайтесь за адресою: rozrahu@gmail.com

ПОБУДОВА ГРАФІКІВ ФУНКЦІЙ

Інформація про навчальний заклад

ВУЗ:
Національний університет Львівська політехніка
Інститут:
О
Факультет:
ЗІ
Кафедра:
Не вказано

Інформація про роботу

Рік:
2014
Тип роботи:
Звіт до лабораторної роботи
Предмет:
Комп'ютерна графіка
Група:
СІ-22

Частина тексту файла

МІНІСТЕРСТВО ОСВІТИ І НАУКИ УКРАЇНИ НАЦІОНАЛЬНИЙ УНІВЕРСИТЕТ “ЛЬВІВСЬКА ПОЛІТЕХНІКА” / ЗВІТ До лабораторної роботи №2 З курсу :”Комп’ютерна графіка” На тему: “ ПОБУДОВА ГРАФІКІВ ФУНКЦІЙ ” Львів 2014 Мета роботи - набути практичних навиків в складанні програм для побудови графіків. ЗАВДАННЯ Написати програму, яка будує в середині екрану систему координат XY і на ній графік функції Y=F(X), якщо аргумент або параметр змінюється на проміжку [а;Ь] з кроком h. / Блок-схема:   СПИСОК ФУНКЦІЙ ВИКОРИСТАНИХ В ПРОГРАМІ for()-цикл. MovcTo(int x, int у) - переміщує поточну вершину, jc, у визначають координати нової поточної вершини. Повертає х- та y-координати попередньої поточної вершини як CPoint об’єкт. LineTo(int x, int y )- малює лінію з поточної вершини до вершини з координатами лс, у. Поточна вершина переміщується у вершину з координатами jc, у. CreatePen(int nPenStyle, int пWidth, COLORREF crColor) - ініціалізує перо заданими атрибутами. TextOutW(int х, int у, const CString& str) - виводить стрічку на екран. х,у задають координати початкової вершини виведення тексту, str об’єкт типу CString, який містить текст для виведення. kx, ky – змінні коефіціентів перетворення; dXmash,dYmash- різниця мінімальних і максимальних координат; Xmash, Ymash – машинні координати; dXreal, dYreal - реальні координати; t – інтервал; xmax, xmin, ymax, ymin, xmin, xmax, ymin, ymax – мінімальні і максимальні значення функції; xc, yc – координати центру екрану; ТЕКСТ ПРОГРАМИ: #include "stdafx.h" #include "PKG lab_2.h" #include "ChildView.h" #include"math.h" #ifdef _DEBUG #define new DEBUG_NEW #endif CChildView::CChildView() { } CChildView::~CChildView() { } BEGIN_MESSAGE_MAP(CChildView, CWnd) ON_WM_PAINT() END_MESSAGE_MAP() BOOL CChildView::PreCreateWindow(CREATESTRUCT& cs) { if (!CWnd::PreCreateWindow(cs)) return FALSE; cs.dwExStyle |= WS_EX_CLIENTEDGE; cs.style &= ~WS_BORDER; cs.lpszClass = AfxRegisterWndClass(CS_HREDRAW|CS_VREDRAW|CS_DBLCLKS, ::LoadCursor(NULL, IDC_ARROW), reinterpret_cast<HBRUSH>(COLOR_WINDOW+1), return TRUE; } void CChildView::OnPaint() { CPaintDC dc(this); // контекст устройства для рисования double i, t, dXreal, dYreal, Kx, Ky, Xmash, Ymash, dXmash=900, dYmash=500, X0mash=640, Y0mash=400, Xmax=-10000, Xmin=10000, Ymax=-10000, Ymin=10000, h=0.5, X, Y; for (t=-100; t<=100; t=t+h) { X=90*cos(t)*sqrt(abs(cos(2*t))); Y=90*sin(t)*sqrt(abs(cos(2*t))); if (Xmax<X) Xmax=X; if (Xmin>X) Xmin=X; if (Ymax<Y) Ymax=Y; if (Ymin>Y) Ymin=Y; } dXreal=Xmax-Xmin; dYreal=Ymax-Ymin; Kx=dXmash/dXreal; Ky=dYmash/dYreal; Xmash=X0mash+X*Kx; Ymash=Y0mash-Y*Ky; dc.MoveTo (X0mash-720, Y0mash); dc.LineTo (X0mash+720, Y0mash); dc.MoveTo (X0mash+720, Y0mash); dc.LineTo (X0mash+715, Y0mash-5); dc.MoveTo (X0mash+720, Y0mash); dc.LineTo (X0mash+715, Y0mash+5); dc.MoveTo (X0mash, Y0mash-400); dc.LineTo (X0mash, Y0mash+400); dc.MoveTo (X0mash, Y0mash-400); dc.LineTo (X0mash-5, Y0mash-395); dc.MoveTo (X0mash, Y0mash-400); dc.LineTo (X0mash+5, Y0mash-395); t=-100; X=90*cos(t)*sqrt(abs(cos(2*t))); Y=90*sin(t)*sqrt(abs(cos(2*t))); Xmash=X0mash+X*Kx; Ymash=Y0mash-Y*Ky; dc.MoveTo (Xmash, Ymash); CPen red_pen; red_pen.CreatePen (PS_SOLID, 2, RGB (255, 0, 0)); dc.SelectObject(&red_pen); for (t=-100; t<=100; t=t+h) { X=90*cos(t)*sqrt(abs(cos(2*t))); Y=90*sin(t)*sqrt(abs(cos(2*t))); Xmash=X0mash+X*Kx; Ymash=Y0mash-Y*Ky; dc.LineTo (Xmash, Ymash); } CPen black; black.CreatePen (PS_SOLID, 1, RGB (0, 0, 0)); dc.SelectObject(&black); for (i=-120; i<=120; i=i+20) { dc.MoveTo (X0mash+i*Kx, Y0mash-3); dc.LineTo (X0mash+i*Kx, Y0mash+3); } for (i=-120; i<=120; i=i+20) { dc.MoveTo (X0mash-3, Y0mash+i*Ky); dc.LineTo (X0mash+3, Y0mash+i*Ky); } const CString X0("0"); dc.TextOutW(X0mash-10,Y0mash+10, X0); const CString X1("-160"); dc.TextOutW(X0mash-165*Kx,Y0mash+10, X...
Антиботан аватар за замовчуванням

14.12.2014 13:12

Коментарі

Ви не можете залишити коментар. Для цього, будь ласка, увійдіть або зареєструйтесь.

Завантаження файлу

Якщо Ви маєте на своєму комп'ютері файли, пов'язані з навчанням( розрахункові, лабораторні, практичні, контрольні роботи та інше...), і Вам не шкода ними поділитись - то скористайтесь формою для завантаження файлу, попередньо заархівувавши все в архів .rar або .zip розміром до 100мб, і до нього невдовзі отримають доступ студенти всієї України! Ви отримаєте грошову винагороду в кінці місяця, якщо станете одним з трьох переможців!
Стань активним учасником руху antibotan!
Поділись актуальною інформацією,
і отримай привілеї у користуванні архівом! Детальніше

Оголошення від адміністратора

Антиботан аватар за замовчуванням

пропонує роботу

Admin

26.02.2019 12:38

Привіт усім учасникам нашого порталу! Хороші новини - з‘явилась можливість кожному заробити на своїх знаннях та вміннях. Тепер Ви можете продавати свої роботи на сайті заробляючи кошти, рейтинг і довіру користувачів. Потрібно завантажити роботу, вказати ціну і додати один інформативний скріншот з деякими частинами виконаних завдань. Навіть одна якісна і всім необхідна робота може продатися сотні разів. «Головою заробляти» продуктивніше ніж руками! :-)

Новини